博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
springSecurity 基于方法权限控制@RolesAllowed @Serured @PreAuthorize 与 页面端标签控制权限...
阅读量:6799 次
发布时间:2019-06-26

本文共 2458 字,大约阅读时间需要 8 分钟。

基于方法权限控制有三种,但都是基于aop的,所以使用需要在springmvc.xml中开启<aop:aspectj-autoproxy proxy-target-class="true"></aop:aspectj-autoproxy>

一.JSR-250注解   @RolesAllowed 表示访问对应方法时所应该具有的角色

  使用前需要导入Jsr-250-api依赖,开启注解 <security:global-method-security jsr250-annotations="enabled"/>

@RolesAllowed("ROLE_ADMIN")  //拥有该角色的才能访问次方法    public ModelAndView findAll() {        ModelAndView mv = new ModelAndView();        List
permissionList=permissionService.findAll(); mv.addObject("permissionList",permissionList); mv.setViewName("permission-list"); return mv; }

二.@Secured注解,这个是springsecurity提供的,不用导入额外依赖

      使用前开启注解 <security:global-method-security secured-annotations="enabled"/>

    

@Secured("ROLE_ADMIN") //拥有该角色的才能访问次方法    public ModelAndView findAll(@RequestParam(name = "page",defaultValue = "1") int page, @RequestParam(name = "pageSize",defaultValue = "4") int pageSize){        ModelAndView mv= new ModelAndView();        List
productList=productService.findAll(page,pageSize); PageInfo pageInfo = new PageInfo(productList); mv.addObject("pageInfo",pageInfo); mv.setViewName("product-list"); return mv; }

 

三.表达式的注解@PreAuthorize

   使用前开启注解 <security:global-method-security pre-post-annotations="enabled"/>

  注意:PreAuthorize(".....")中采用的是SpEL表达式,常用的有:hasRole('ROLE_USER'),hasAnyRole('ROLE_USER','ROLE_ADMIN',...)

    authentication.principal.username=='tom' -->用户名为tom的才能访问

@PreAuthorize("hasRole('ROLE_ADMIN')")//使用SpEL表达式,有该角色才能访问次方法    public ModelAndView findAll(@RequestParam(name = "page",defaultValue = "1") int page, @RequestParam(name = "pageSize",defaultValue = "4") int pageSize){        ModelAndView mv= new ModelAndView();        List
productList=productService.findAll(page,pageSize); PageInfo pageInfo = new PageInfo(productList); mv.addObject("pageInfo",pageInfo); mv.setViewName("product-list"); return mv; }

 

 

 

 

------------------------------------------------------------------------------------------------------

    一.  页面端标签控制权限与用户名显示

      开启aop自动代理<aop:aspectj-autoproxy proxy-target-class="true"></aop:aspectj-autoproxy>

      1).导入依赖spring-security-taglibs

      2).页面引入<%@taglib uri="http://www.springframework.org/security/tags" prefix="security"%>

    

//拥有该角色才显示里面的内容,否者隐藏起来
  • 访问日志
  •       显示用户名也需要导入依赖和引入标签

    //上面两种都可以显示登录用户名

     

        

    转载于:https://www.cnblogs.com/georgeJavaEE/p/9851880.html

    你可能感兴趣的文章
    Hive系列之HSQL转换成MapReduce过程
    查看>>
    Windows cannot find the local profile and is logging you on with a temporary profile
    查看>>
    oracle教程之oracle动态采样(一)
    查看>>
    我的友情链接
    查看>>
    PHP数组函数
    查看>>
    vue+typescript入门学习
    查看>>
    我的友情链接
    查看>>
    我的友情链接
    查看>>
    linix下的php源码安装
    查看>>
    php session阻塞页面分析及优化
    查看>>
    HTTP状态码
    查看>>
    使用log4net配置相关信息
    查看>>
    Linux系统编程笔记
    查看>>
    jQuery.noConflict() 方法—— jquery库与其他库冲突的问题解决
    查看>>
    linux下inet_ntoa(包括inet_ntop)和printf的使用问题
    查看>>
    关于Linux 中getopt_long的用法
    查看>>
    【吾日三省吾身】2015.6.06-涅槃行动第十九天
    查看>>
    我的友情链接
    查看>>
    DRBD群集搭设
    查看>>
    我的友情链接
    查看>>